package com.bihua.iot.domain.vo;

import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import com.bihua.common.annotation.ExcelDictFormat;
import com.bihua.common.convert.ExcelDictConvert;
import lombok.Data;
import java.util.Date;



/**
 * 产品设备下发服务命令属性视图对象 product_commands_requests
 *
 * @author bihua
 * @date 2023-06-15
 */
@Data
@ExcelIgnoreUnannotated
public class ProductCommandsRequestsVo {

    private static final long serialVersionUID = 1L;

    /**
     * id
     */
    @ExcelProperty(value = "id")
    private Long id;

    /**
     * 服务ID
     */
    @ExcelProperty(value = "服务ID")
    private Long serviceId;

    /**
     * 命令ID
     */
    @ExcelProperty(value = "命令ID")
    private Long commandsId;

    /**
     * 指示数据类型。取值范围：string、int、decimal

     */
    @ExcelProperty(value = "指示数据类型")
    private String datatype;

    /**
     * 指示枚举值。
如开关状态status可有如下取值
"enumList" : ["OPEN","CLOSE"]
目前本字段是非功能性字段，仅起到描述作用。建议准确定义。

     */
    @ExcelProperty(value = "指示枚举值")
    private String enumlist;

    /**
     * 指示最大值。
仅当dataType为int、decimal时生效，逻辑小于等于。
     */
    @ExcelProperty(value = "指示最大值")
    private Integer max;

    /**
     * 指示字符串长度。
仅当dataType为string时生效。
     */
    @ExcelProperty(value = "指示字符串长度")
    private Integer maxlength;

    /**
     * 指示最小值。
仅当dataType为int、decimal时生效，逻辑大于等于。
     */
    @ExcelProperty(value = "指示最小值")
    private Integer min;

    /**
     * 命令中参数的描述，不影响实际功能，可配置为空字符串""。
     */
    @ExcelProperty(value = "命令中参数的描述")
    private String parameterDescription;

    /**
     * 命令中参数的名字。
     */
    @ExcelProperty(value = "命令中参数的名字。")
    private String parameterName;

    /**
     * 指示本条属性是否必填，取值为0或1，默认取值1（必填）。
目前本字段是非功能性字段，仅起到描述作用。
     */
    @ExcelProperty(value = "指示本条属性是否必填，取值为0或1，默认取值1", converter = ExcelDictConvert.class)
    @ExcelDictFormat(readConverterExp = "必=填")
    private Integer required;

    /**
     * 指示步长。
     */
    @ExcelProperty(value = "指示步长。")
    private Integer step;

    /**
     * 指示单位。
取值根据参数确定，如：
•温度单位：“C”或“K”
•百分比单位：“%”
•压强单位：“Pa”或“kPa”

     */
    @ExcelProperty(value = "指示单位")
    private String unit;


}
